<!doctype html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta
        name="viewport"
        content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"
    >
    <meta
        http-equiv="X-UA-Compatible"
        content="ie=edge"
    >
    <title>VueComponent</title>
    <script src="../vue.js"></script>
</head>

<body>
    <!--
			关于VueComponent：
						1.school组件本质是一个名为VueComponent的构造函数，且不是程序员定义的，是Vue.extend生成的。

						2.我们只需要写<school/>或<school></school>，Vue解析时会帮我们创建school组件的实例对象，
							即Vue帮我们执行的：new VueComponent(options)。

						3.特别注意：每次调用Vue.extend，返回的都是一个全新的VueComponent！！！！注意这一点很重要

						4.关于this指向：
								(1).组件配置中：
											data函数、methods中的函数、watch中的函数、computed中的函数 它们的this均是【VueComponent实例对象】。
								(2).new Vue(options)配置中：
											data函数、methods中的函数、watch中的函数、computed中的函数 它们的this均是【Vue实例对象】。

						5.VueComponent的实例对象，以后简称vc（也可称之为：组件实例对象）。
							Vue的实例对象，以后简称vm。 vm管理着一个又一个vc，vc可以再嵌套vc
					    6.因为组件是可复用的 Vue 实例，所以它们与 new Vue 接收相同的选项，例如 data、computed、watch、methods 以及生命周期钩子等。仅有的例外是像 el 这样根实例特有的选项。
					      所以vm与vc属性配置并不是一模一样，尽管vc底层复用了很多vm的逻辑
-->
    <div id="root">
        <school></school>
        <hello>
        </hello>
    </div>



    <script type="text/javascript">
        Vue.config.productionTip = false;

        const school = Vue.extend({
            template: `
          <div>
             <h1>学校名称:{{ name }}</h1>
             <h1>学校地址:{{ address }}</h1>
             <button @click="showname">点我提示学校名</button>
          </div>
        `,
            data () {
                return {
                    name: '武汉科技大学',  //vuecomponent的实例对象
                    address: '武汉'
                }
            },
            methods: {
                showname () {
                    console.log(this);
                    console.log('showName',this.name);
                }
            }
        });

        // console.log(typeof school, school); //所谓的组件就是构造函数(VueComponent);
        //测试组件
        const test = Vue.extend({
            template: `<h1>panyue</h1>`
        });

        //hello组件
        const hello = Vue.extend({
            template: `
          <div>
          <h1>{{ msg }}</h1>
          <test></test>
          </div>`,
            data () {
                return {
                    msg: '你好'
                }
            },
            components: {
                test
            }
        })


        const vm = new Vue({
            el: "#root",
            components: {
                school,
                hello
            }
        });

        //验证school与hello并不是同一个VueComponent构造函数
        // school.a = 99;
        console.log('@', school);
        console.log('#', hello);
        // console.log(school === hello);
        // console.log(school.a, hello.a);
    </script>
</body>

</html>